package cn.rxls.community.mapper;

import cn.rxls.community.dto.goods.GoodsPageDTO;
import cn.rxls.community.entity.Goods;
import cn.rxls.community.vo.goods.GoodsVO;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;


/**
 * 商品(Goods)表数据库访问层
 *
 * @author makejava
 * @since 2024-06-04 12:05:01
 */
@Mapper
public interface GoodsMapper extends BaseMapper<Goods> {

    /**
     * 分页查询状态为1的数据
     *
     * @param page  第几页
     * @param size  查几个
     * @param id    分类id
     * @param state 状态
     * @return 多条商品信息
     */
    List<GoodsVO> selectPageGoodsByCategory(@Param("page") Integer page,
                                            @Param("size") Integer size,
                                            @Param("id") Long id,
                                            @Param("state") Integer state
    );

    /**
     * 根据主键id查询
     *
     * @param id 主键id
     * @return 单条商品信息
     */
    GoodsVO selectDetail(@Param("id") Long id);


    /**
     * 库存扣减-乐观锁
     * @param id 商品id
     * @param num 扣减数量
     * @param inventory 商品库存
     * @return 成功数
     */
    Integer inventoryDeductions(@Param("id") Long id,@Param("num") Integer num,@Param("inventory") Integer inventory);
}

